{% extends "layout/basic.html" %}
{% load static %}


{% block title %} 用户注册{% endblock %}

{% block css %}
    <link rel="stylesheet" href="{% static 'css/account.css' %}">
    <style>
        .error-msg {
            color: red;
            position: absolute;
            font-size: 13px;
        }
    </style>
{% endblock %}


{% block content %}
    {#    因为想保留母版页面的格式所以我们这里class="container"#}
    <div class="account">
        <div class="title">用户注册</div>
        <form id="regForm" method="POST" novalidate>
            {% csrf_token %}
            {% for field in form %}
                {% if field.name == 'code' %}
                    <div class="form-group">
                        <label for="{{ field.id_for_label }}">{{ field.label }}</label>
                        <div class="row">
                            <div class="col-xs-7">
                                {{ field }}
                                <span class="error-msg"></span>
                            </div>
                            <div class="col-xs-5">
                                <input id="btnSms" type="button" class="btn btn-default" value="点击获取验证码">
                            </div>
                        </div>
                    </div>
                {% else %}
                    <div class="form-group">
                        <label for="{{ field.id_for_label }}">{{ field.label }}</label>
                        {{ field }}
                        <span class="error-msg"></span>
                    </div>
                {% endif %}
            {% endfor %}

            <div class="row">
                <div class="col-xs-3">
                    <input id="btnSubmit" type="button" class="btn btn-primary" value="注  册"/>
                </div>
            </div>
        </form>
    </div>

{% endblock %}



{% block js %}
    <script>
        //页面框架加载完成之后自己执行函数
        $(function () {
            bindClickBtnSms();
            bindClickSubmit();
        });

        /*
           使用ajax点击提交获取每个字段中的数据
        */
        function bindClickSubmit() {
            $('#btnSubmit').click(function () {
                $('.error-msg').empty();
                // 收集表单中的数据（找到每一个字段）$('#regForm').serialize()
                // 数据ajax发送到后台
                $.ajax({
                    url: "{% url 'register' %}",
                    type: "POST",
                    data: $('#regForm').serialize(), // 所有字段数据 + csrf token
                    dataType: "JSON",
                    success: function (res) {
                        if(res.status){
                            location.href = res.data; //接收后端发送的数据，然后跳转
                        }else{
                            $.each(res.error, function (key, value) {
                                $("#id_" + key).next().text(value[0]);
                            })
                        }
                    }
                })
            })
        }


        /*
        点击获取验证码的按钮绑定事件
         */
        function bindClickBtnSms() {

            $("#btnSms").click(function () {
                $(".error-msg").empty();
                //获取用户输入的手机号
                //找到手机号的输入框，获取输入框中的内容(因为我们是用modelForm自动生成的，所以我们查看原码看不同之处)
                var mobilePhone = $('#id_mobile_phone').val();
                {#alert(mobliePhone)#}

                //发送ajax ，把手机号发送过去用sms开始发送短信
                $.ajax({
                    url: "/send_sms/",  //发送的位置 https://xx.com/send_sms?moblie_phone=xxx&tpl=register
                    type: "GET",    //方式
                    data: {mobile_phone: mobilePhone, tpl: "register"},
                    dataType: "JSON",
                    success: function (res) {
                        //ajax请求发送成功之后，自动执行的函数，res就是后端返回给前端的内容
                        if (res.status) {
                            sendSmsRemind();
                        } else {
                            // 错误信息
                            // console.log(res); // {status:False, error:{ mobile_phone: ["错误信息"，],code: ["错误信息"，] }  }
                            $.each(res.error, function (key, value) {
                                $("#id_" + key).next().text(value[0]);
                            })
                        }
                    }
                })
            })

        }

        /*
        倒计时
        */
        function sendSmsRemind() {
            var smsBtn = $('#btnSms');
            smsBtn.prop('disabled', true);
            var time = 60;
            var remind = setInterval(function () {
                smsBtn.val(time + '秒重新发送');
                time = time - 1;
                if (time < 1) {
                    clearInterval(remind);
                    smsBtn.val('点击获取验证码').prop('disabled', false);
                }
            }, 1000)
        }
    </script>
{% endblock %}
